#include <iostream>
#include <queue>
#include <map>
#include <unordered_map>
#include <vector>
#include <algorithm>
#include <cmath>
#include <string>
#include <cstring>
#include <set>
#include <unordered_set>
using namespace std;
typedef long long ll;
typedef unsigned long long Ull;
const int N=5e6+10;
int h[N];
int main()
{
	int n;
	cin>>n;
	memset(h,-1,sizeof(h));
	for(int c=0;c*c<=n;c++)
	{
		for(int d=c;d*d+c*c<=n;d++)
		{
			int t=d*d+c*c;
			if(h[t]==-1)
			{
				h[t]=c;
			}
		}
	}
	for(int a=0;a*a<=n;a++)
	{
		for(int b=a;b*b+a*a<=n;b++)
		{
			int t=a*a+b*b;
			if(h[n-t]!=-1)
			{
				cout<<a<<' '<<b<<' '<<h[n-t]<<' '<<(int)sqrt(n-t-h[n-t]*h[n-t]);
				return 0; 
			}
		}
	}

	return 0;
}

